- 
                Notifications
    You must be signed in to change notification settings 
- Fork 8k
Use ZendMM for libgmp #16507
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use ZendMM for libgmp #16507
Conversation
As is, ext/gmp uses the default memory allocator of the underlying libgmp; this allocator is fallible, but contrary to ZendMM, it `abort()`s without giving us an opportunity to do a cleaner shutdown. Furthermore, the libgmp allocator obviously doesn't heed memory_limit. Thus we install wrappers of the ZendMM API as libgmp allocator.
| I have a concern. Suppose we're on ZTS with a multithreaded server like Apache for example. | 
| @nielsdos, very valid concern – I haven't thought about threads. Thank you! I guess we have to forget about using ZendMM then. If only libgmp wouldn't  | 
| If the intention is to prevent aborts, then we can still override the routines with our own but do some extra checks before calling system malloc | 
| I don't think there is much we can do. If a library is written with an infallible (mixed that up in the OP) allocator in mind, it is unlikely that it is up to deal with a fallible allocator. E.g. So even if we add some checks before calling system malloc, we cannot simply return NULL, but need to bail out. Additionally, it seems to me that  And I'm actually even more concerned about mpir apparently being discontinued. Last version is 3.0.0 from 2017. Maybe https://github.com/BrianGladman/mpir could be used, but apparently they don't tag or even release. | 
| 
 Isn't this a concern in general for setting ZendMM as an allocator for a given C library? If yes, how do we deal with this in other cases? | 
| This is indeed a general concern when the allocator settings are not threaded too. | 
| 
 I don't think so; some libs are bundled to use ZendMM (e.g.libmagic, libgd). | 
As is, ext/gmp uses the default memory allocator of the underlying libgmp; this allocator is infallible, but contrary to ZendMM, it
abort()s without giving us an opportunity to do a cleaner shutdown. Furthermore, the libgmp allocator obviously doesn't heed memory_limit. Thus we install wrappers of the ZendMM API as libgmp allocator.I've targeted
mastersince this might be seen as new feature; it might also been seen as bug fix, though.